package proyecto.dao;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

import proyecto.excepcion.DAOExcepcion;
import proyecto.modelo.Usuario;
import proyecto.util.ConexionBD;

public class UsuarioDAO extends BaseDAO {

public Usuario insertar(Usuario vo) throws DAOExcepcion {
		
		System.out.println("UsuarioDAO: insertar(Usuario vo)");
		String query = "INSERT INTO usuario(idUsuario, nombre, apellidoPaterno, apellidoMaterno, sexo, tipoDocumento, numeroDocumento, email, celular, clave, rol, idPerfil) VALUES (?,?,?,?,?,?,?,?,?,?,?,?)";
		Connection con = null;
		PreparedStatement stmt = null;
		ResultSet rs = null;
		try {
			con = ConexionBD.obtenerConexion();
			stmt = con.prepareStatement(query);
			
			
			stmt.setInt(1, vo.getIdUsuario());
			stmt.setString(2, vo.getNombre());
			stmt.setString(3, vo.getApellidoPaterno());
			stmt.setString(4, vo.getApellidoMaterno());
			stmt.setString(5, vo.getSexo());
			stmt.setString(6, vo.getTipoDocumento());
			stmt.setInt(7, vo.getNumeroDocumento());
			stmt.setString(8, vo.getEmail());
			stmt.setInt(9, vo.getCelular());
			stmt.setString(10, vo.getClave());
			stmt.setString(11, vo.getRol());
			stmt.setInt(12, vo.getIdPerfil());
			
			
			
			System.out.println("Se inserto al Usuario satisfactoriamente");
			int i = stmt.executeUpdate();
			if (i == 0) {
				throw new SQLException("No se pudo insertar al Usuario");
			}
			
			// Obtener el ultimo id
			int id = 0;
			query = "SELECT LAST_INSERT_ID()";
			stmt = con.prepareStatement(query);
			rs = stmt.executeQuery();
			if (rs.next()) {
				id = rs.getInt(1);
			}
			vo.setIdUsuario(id);
			
		} catch (SQLException e) {
			System.err.println(e.getMessage());
			throw new DAOExcepcion(e.getMessage());
		} finally {
			this.cerrarResultSet(rs);
			this.cerrarStatement(stmt);
			this.cerrarConexion(con);
		}
		return vo;
	}



}
